#include <iostream>
#include <vector>
#include <algorithm>
#include <cmath>
#include <set>
#include <iomanip>
struct LightHouse {
long double x_{0};
long double y_{0};
long double a_{0};
};
long double Dist(const LightHouse& lh, long double d, long double r) {
if (d == r) {
return r;
}
long double pi = std::acos(-1.0);
long double rad = (pi * lh.a_) / 180.0;
std::pair<long double, long double> p = std::make_pair((d - lh.x_) * std::cos(rad) + lh.y_ * std::sin(rad),
(d - lh.x_) * std::sin(rad) - lh.y_ * std::cos(rad));
if (p.second > -1e-10) {
return r;
}
p.first /= p.second;
return std::min(std::max(lh.x_ - lh.y_ * p.first, d), r);
}
long double MaxPath(long double l, long double r, const std::vector<LightHouse>& v) {
std::vector<long double> opt(1 << (v.size()), l);
for (size_t i = 0; i < (1 << (v.size())); i++) {
for (size_t j = 0; j < v.size(); j++) {
if (!((i >> j) & 1)) {
opt[(i | (1 << j))] = std::max(opt[(i | (1 << j))], Dist(v[j], opt[i], r));
}
}
}
return opt.back() - l;
}
int main() {
size_t n = 0;
std::cin >> n;
long double l = 0;
long double r = 0;
std::cin >> l >> r;
std::vector<LightHouse> v(n);
for (size_t i = 0; i < n; i++) {
std::cin >> v[i].x_ >> v[i].y_ >> v[i].a_;
}
std::cout << std::fixed;
std::cout.precision(8);
std::cout << MaxPath(l, r, v);
return 0;
}
516. Longest Palindromic Subsequence | 468. Validate IP Address |
450. Delete Node in a BST | 445. Add Two Numbers II |
442. Find All Duplicates in an Array | 437. Path Sum III |
436. Find Right Interval | 435. Non-overlapping Intervals |
406. Queue Reconstruction by Height | 380. Insert Delete GetRandom O(1) |
332. Reconstruct Itinerary | 368. Largest Divisible Subset |
377. Combination Sum IV | 322. Coin Change |
307. Range Sum Query - Mutable | 287. Find the Duplicate Number |
279. Perfect Squares | 275. H-Index II |
274. H-Index | 260. Single Number III |
240. Search a 2D Matrix II | 238. Product of Array Except Self |
229. Majority Element II | 222. Count Complete Tree Nodes |
215. Kth Largest Element in an Array | 198. House Robber |
153. Find Minimum in Rotated Sorted Array | 150. Evaluate Reverse Polish Notation |
144. Binary Tree Preorder Traversal | 137. Single Number II |